招生考试网
学历| 高考 美术高考 考研 自考 成考 专升本 中考 会考 外语| 四六级 职称英语 商务英语 公共英语 日语能力 翻译资格 JTEST
资格| 公务员 报关员 银行从业 司法 导游 教师资格 报关 财会| 会计证 经济师 会计职称 注册会计 税务师 资产评估 审计师
工程| 一建 二建 造价师 造价员 咨询师 监理师 安全师 医学| 卫生资格 执业医师 执业药师 执业护士 | 教案 论文 文档
IT类| 计算机等级 计算机软考 职称计算机 高校计算机 推荐-国家公务员 事业单位招聘 军校国防生 自主招生 艺术特长生 招飞
 3773考试网 - 计算机等级考试 - 模拟试题 - 正文

2014年3月全国计算机二级C语言上机模拟试题五十一3

来源:2exam.com 2013-11-12 16:18:58

解题思路: 

  第一处:应求累加和,而不赋值,所以应改为t+=s[k];。 

  第二处:ave不需要取地址,直接赋给*aver就可以了。 

  *************************************************** 

  请编写函数fun,其功能是求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。 

  例如, 输入如下整数: 876 675 896 101 301 401 980 431 451 777 

  则输出结果为: 6, 980 

  注意: 部分源程序在文件PROG1.C文件中。 

  请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。 

  给定源程序: 

  #include  

  int fun(int *s, int t, int *k) 

  { 

  } 

  main( ) 

  { 

  int a[10]={876,675,896,101,301,401,980,431,451,777}, k ; 

  fun(a, 10, &k) ; 

  printf("%d, %d\n", k, a[k]) ; 

  NONO( ) ; 

  } 

  解题思路: 

  本题是考察考生如何在指定的数组找出最大元素值的下标,通过形参*k返回到主程序中。给出的程序是使用for循环语句进行处理的,在循环之前,首先把数组的第一个元素值赋给最大值变量max,位置pos为0,然后通过循环依次判断下一元素值是否大于最大值max,如果大于,那么把这个数重新赋给max,位置i赋给pos,循环结果,即可得到最大值的位置pos,最后执行语句*k=pos就可以实现返回了。 

  参考答案: 

  int fun(int *s, int t, int *k) 

  { 

  int i, pos = 0, max = *s ; 

  for(i = 1 ; i < t ; i++) { 

  if(max < *(s + i)) { 

  max = *(s + i) ; 

  pos = i ; 

  } 

  } 

  *k = pos ; 

  } 


  • 上一个文章:
  • 网站版权与免责声明
    ①由于各方面情况的不断调整与变化,本网所提供的相关信息请以权威部门公布的正式信息为准.
    ②本网转载的文/图等稿件出于非商业性目的,如转载稿涉及版权及个人隐私等问题,请在两周内邮件fjksw@163.com联系.
     


    | 关于我们 | 联系我们 | 版权申明 | 网站导航 |
    琼ICP备12003406号